Les instructions SQL ANY et ALL vous permettent d'effectuer des comparaisons entre la valeur d'une colonne et une plage d'autres valeurs.
Opérateur ANY :
ANY signifie que la condition sera vraie si l'opération est vraie pour l'une des valeurs de la plage.
SELECT column_name(s)
FROM table_name
WHERE column_name operator ANY
(SELECT column_name
FROM table_name
WHERE condition)
Opérateur ALL :
ALL signifie que la condition ne sera vraie que si l'opération est vraie pour toutes les valeurs de la plage.
SELECT ALL column_name(s)
FROM table_name
WHERE condition
SELECT column_name(s)
FROM table_name
WHERE column_name operator ALL
(SELECT column_name
FROM table_name
WHERE condition)
Voici un exemple de la table « Products » (« Produits ») de la base de données « Northwind » :
ProductID | ProductName | SupplierID | CategoryID | Unit | Price |
---|---|---|---|---|---|
1 | Chais | 1 | 1 | 10 boxes x 20 bags | 18.00 |
2 | Chang | 1 | 1 | 24 - 12 oz bottles | 19.00 |
3 | Aniseed Syrup | 1 | 2 | 12 - 550 ml bottles | 10.00 |
4 | Chef Anton's Cajun Seasoning | 2 | 2 | 48 - 6 oz jars | 22.00 |
5 | Chef Anton's Gumbo Mix | 2 | 2 | 36 boxes | 21.35 |
6 | Grandma's Boysenberry Spread | 3 | 2 | 12 - 8 oz jars | 25.00 |
7 | Uncle Bob's Organic Dried Pears | 3 | 7 | 12 - 1 lb pkgs. | 30.00 |
8 | Northwoods Cranberry Sauce | 3 | 2 | 12 - 12 oz jars | 40.00 |
9 | Mishi Kobe Niku | 4 | 6 | 18 - 500 g pkgs. | 97.00 |
10 | Ikura | 4 | 8 | 12 - 200 ml jars | 31.00 |
Et l'échantillon du tableau "OrderDetails" ("Détails de la commande") :
OrderDetailID | OrderID | ProductID | Quantity |
---|---|---|---|
1 | 10248 | 11 | 12 |
2 | 10248 | 42 | 10 |
3 | 10248 | 72 | 5 |
4 | 10249 | 14 | 9 |
5 | 10249 | 51 | 40 |
6 | 10250 | 41 | 10 |
7 | 10250 | 51 | 35 |
8 | 10250 | 65 | 15 |
9 | 10251 | 22 | 6 |
10 | 10251 | 57 | 15 |
La requête SQL suivante répertorie ProductName si elle trouve un enregistrement (ANY) dans la table OrderDetails avec une valeur Quantity égale à 10 (cela renverra TRUE car la colonne Quantity a des valeurs de 10) :
Run SQLSELECT ProductName
FROM Products
WHERE ProductID = ANY
(SELECT ProductID
FROM OrderDetails
WHERE Quantity = 10)
La requête SQL suivante répertorie ProductName si elle trouve un enregistrement (ANY) dans la table OrderDetails avec une quantité supérieure à 99 (cela renverra TRUE car la colonne Quantity contient des valeurs supérieures à 99) :
Run SQLSELECT ProductName
FROM Products
WHERE ProductID = ANY
(SELECT ProductID
FROM OrderDetails
WHERE Quantity > 99)
Une autre instruction SQL répertorie ProductName si elle trouve un enregistrement (ANY) dans la table OrderDetails avec une quantité supérieure à 1000 (cela renverra FALSE car la colonne Quantity ne contient pas de valeurs supérieures à 1000) :
Run SQLSELECT ProductName
FROM Products
WHERE ProductID = ANY
(SELECT ProductID
FROM OrderDetails
WHERE Quantity > 1000)
L'instruction SQL suivante répertorie tous les noms de produits (ALL) :
Run SQLSELECT ALL ProductName
FROM Products
WHERE TRUE
L'instruction SQL suivante répertorie ProductName si tous les enregistrements (ALL) de la table OrderDetails ont un nombre égal à 10. Bien sûr, cela renverra FALSE car la colonne Quantity a de nombreuses valeurs différentes (pas seulement la valeur 10) :
Run SQLSELECT ProductName
FROM Products
WHERE ProductID = ALL
(SELECT ProductID
FROM OrderDetails
WHERE Quantity = 10)